public class Test2 {
    //leetcode 198 打家劫舍
    public int rob(int[] nums) {
        int n = nums.length;
        int[] f = new int[n]; //f[i]表示i位置偷，以该位置为结尾偷的最多
        int[] g = new int[n];
        f[0] = nums[0]; g[0] = 0;
        for (int i = 1; i < n; i++) {
            f[i] = g[i-1] + nums[i];
            g[i] = Math.max(g[i-1],f[i-1]);
        }
        return Math.max(f[n-1],g[n-1]);
    }
}
